const path = require('path')
const isProd = process.env.NODE_ENV === 'production'

function resolve (dir) {
  return path.join(__dirname, dir)
}

module.exports = {
  runtimeCompiler: true,
  assetsDir: 'public',
  publicPath: isProd ? './' : '/',
  // webpack的相关配置
  configureWebpack: {
    entry: './src/renderer/main.js',
    resolve: {
      extensions: [ '.js', '.vue', '.json', '.ts', '.less' ],
      alias: {
        '@': resolve('src/renderer')
      }
    },
    module: {
      rules: [ {
        test: /\.(html)(\?.*)?$/,
        use: 'vue-html-loader'
      }
      ]
    },
    // 公共资源合并
    optimization: {
      splitChunks: {
        cacheGroups: {
          vendor: {
            chunks: 'all',
            test: /node_modules/,
            name: 'vendor',
            minChunks: 1,
            maxInitialRequests: 5,
            minSize: 0,
            priority: 100
          },
          common: {
            chunks: 'all',
            test: /[\\/]src[\\/]js[\\/]/,
            name: 'common',
            minChunks: 2,
            maxInitialRequests: 5,
            minSize: 0,
            priority: 60
          },
          styles: {
            name: 'styles',
            test: /\.(sa|sc|le|c)ss$/,
            chunks: 'all',
            enforce: true
          },
          runtimeChunk: {
            name: 'manifest'
          }
        }
      }
    },
    // 性能警告修改
    performance: {
      hints: 'warning',
      // 入口起点的最大体积 整数类型（以字节为单位）
      maxEntrypointSize: 50000000,
      // 生成文件的最大体积 整数类型（以字节为单位 300k）
      maxAssetSize: 30000000,
      // 只给出 js 文件的性能提示
      assetFilter: function (assetFilename) {
        return assetFilename.endsWith('.js')
      }
    }
  },
  chainWebpack: config => {},
  // 打包输出路径
  outputDir: 'dist',
  productionSourceMap: false,
  // 构建时开启多进程处理 babel 编译
  //  parallel: require('os').cpus().length > 1,
  css: {
    // 是否使用css分离插件 ExtractTextPlugin
    extract: isProd,
    // 开启 CSS source maps?
    sourceMap: !isProd,
    // css预设器配置项
    loaderOptions: {
      less: {
        javascriptEnabled: true
      }
    },
    // 启用 CSS modules for all css / pre-processor files.
    requireModuleExtension: true
  },
  // 开发服务器http代理
  devServer: {
    open: !process.argv.includes('electron:serve'),
    host: 'localhost',
    port: 9081,
    https: false,
    hotOnly: false
    // proxy: {
    //   '/api': {
    //     target: 'http://localhost:9999/',
    //     changeOrigin: true, // 是否跨域
    //     ws: true, // 代理长连接
    //     pathRewrite: {
    //       '^/api': '/'
    //     } // 重写接口
    //   },
    //   '/socket': {
    //     target: 'ws://localhost:9999/',
    //     ws: true
    //   }
    // }
  },
  // 第三方插件配置
  pluginOptions: {
    // vue-cli-plugin-electron-builder配置
    electronBuilder: {
      builderOptions: {
        win: {
          icon: 'public/app.ico',
          // 图标路径 windows系统中icon需要256*256的ico格式图片，更换应用图标亦在此处
          target: [ {
            // 打包成一个独立的 exe 安装程序
            target: 'nsis',
            // 这个意思是打出来32 bit + 64 bit的包，但是要注意：这样打包出来的安装包体积比较大，所以建议直接打32的安装包。
            'arch': [
              // 'x64'
              'ia32'
            ]
          } ]
        },
        files: [ '**/*' ],
        asar: false,
        nsis: {
          // 是否一键安装，建议为 false，可以让用户点击下一步、下一步、下一步的形式安装程序，如果为true，当用户双击构建好的程序，自动安装程序并打开，即：一键安装（one-click installer）
          oneClick: true,
          // 允许请求提升。 如果为false，则用户必须使用提升的权限重新启动安装程序。
          allowElevation: true,
          // 允许修改安装目录，建议为 true，是否允许用户改变安装目录，默认是不允许
          allowToChangeInstallationDirectory: false,
          // 安装图标
          installerIcon: 'public/app_min.ico',
          // 卸载图标
          uninstallerIcon: 'public/app_min.ico',
          // 安装时头部图标
          installerHeaderIcon: 'public/app_min.ico',
          // 创建桌面图标
          createDesktopShortcut: true,
          // 创建开始菜单图标
          createStartMenuShortcut: true
        }
      },
      chainWebpackMainProcess: config => {
        config.plugin('define').tap(args => {
          args[ 0 ][ 'IS_ELECTRON' ] = true
          return args
        })
      },
      chainWebpackRendererProcess: config => {
        config.plugin('define').tap(args => {
          args[ 0 ][ 'IS_ELECTRON' ] = true
          return args
        })
      },
      outputDir: 'dist',
      mainProcessFile: 'src/main/main.js',
      mainProcessWatch: [ 'src/main' ]
    }
  }
}
